## 8-Leds

| Description | PIC32 pin      | Schematic | Label |            | LEDs            |
|-------------|----------------|-----------|-------|------------|-----------------|
|             |                | name      |       | LEDO R17   | <del>- 13</del> |
| Led 0       | TMS/CTED1/RAO  | LED0      | LD0   | 330<br>R19 | LD0             |
| Led 1       | TCK/CTED2/RA1  | LED1      | LD1   | TED1 -     | <del>1</del>    |
| Led 2       | SCL2/RA2       | LED2      | LD2   | 330<br>R23 | LD1             |
| Led 3       | SDA2/RA3       | LED3      | LD3   | 330        |                 |
| Led 4       | TDI/CTED9/RA4  | LED4      | LD4   | LED3 R28   | LD2             |
| Led 5       | TDO/RA5        | LED5      | LD5   | 330        | LD3             |
| Led 6       | TRCLK/RA6      | LED6      | LD6   | LED4 R32   | <b>₹</b> 3      |
| Led 7       | TRD3/CTED8/RA7 | LED7      | LD7   | 330        | LD4             |
|             |                |           |       | LED5 R38   | N)              |
|             |                |           | 1     | 330        | LD5             |
|             |                |           |       | LED6 R41   | Ö               |
|             |                |           |       | 330<br>R42 | ĹD6             |
|             | led            | PORTA     |       | LED/       | GND             |
|             | 100.           | RA8-RA15  |       | 330        | LD7             |
|             |                |           |       |            |                 |
|             |                |           |       |            |                 |

```
Ports Macro's:

#define LD0 PORTAbits.RA0

#define LD1 PORTAbits.RA1

#define LD2 PORTAbits.RA2

#define LD3 PORTAbits.RA3

#define LD4 PORTAbits.RA4

#define LD5 PORTAbits.RA5

#define LD6 PORTAbits.RA6

#define LD7 PORTAbits.RA7
```

```
#include <xc.h>
                                      TRIS
#pragma config JTAGEN = OFF
                                       0 = output
                                                         1 = input
#pragma config FWDTEN = OFF
                                       הגדרת הפורט ככניסה הגדרת הפורט כיציאה
#pragma config FNOSC =FRCPLL
                                                 מהבקר.
                                                                     לבקר.
#pragma config FSOSCEN = OFF
                                          – כותבים ליציאה)
                                                            – (קוראים מהפורט)
#pragma config POSCMOD =
                             EC
                                            הפורט משתנה
                                                               הפורט משתנה
#pragma config OSCIOFNC =
                            ON
#pragma config FPBDIV = DIV 1
                                         בעקבות שינוי בקוד:
                                                           בעקבות שינוי חיצוני:
#pragma config FPLLIDIV =
                             DIV 2
                                         כיבוי והפעלת לדים
                                                            לחיצת/עזיבת מקש
#pragma config FPLLMUL =
                                                                       ..IOI
MUL 20
#pragma config FPLLODIV =
                              DIV 1
void main(){
                                         //
                                                 הגדרת PORTA כיציאה (RAO-RA7).
    //init starts *******
    TRISA &= 0xff00;
    //init ends ********
                                         // .(0,2,4,6 מספר זוגי: RAi (מספר זוגי: 1,0,2,4,6).
    PORTA = 0x55;
                                                          Ox55=0b10101010 '>
```

## **Switches**

| Description | PIC32 pin                            | Schem' name | Label |
|-------------|--------------------------------------|-------------|-------|
|             |                                      |             |       |
| Switch 0    | RPF3/RF3                             | SW0         | SW0   |
| Switch 1    | RPF5/PMA8/RF5                        | SW1         | SW1   |
| Switch 2    | RPF4/PMA9/ <mark>RF4</mark>          | SW2         | SW2   |
| Switch 3    | RPD15/RD15                           | SW3         | SW3   |
| Switch 4    | RPD14/RD14                           | SW4         | SW4   |
| Switch 5    | AN11/PMA12/RB11                      | SW5         | SW5   |
| Switch 6    | CVREFOUT/AN10/RPB10/CTED11PMA13/RB10 | SW6         | SW6   |
| Switch 7    | AN9/RPB9/CTED4/RB9                   | SW7         | SW7   |

```
Switches
Ports Macro's:
#define SWO PORTFbits.RF3
#define SW1 PORTFbits.RF5
                                                                                              SW0
                                                                                      R21 10K
#define SW2 PORTFbits.RF4
                                                                                              SW1
                                                                                      10K R24
#define SW3 PORTDbits.RD15
                                                                                              SW2
                                                                                      R27 10K
#define SW4 PORTDbits.RD14
                                                                                              SW3
                                                                   SW3
#define SW5 PORTBbits.RB11
                                                                                              SW4
                                                                                      R33 10K
#define SW6 PORTBbits.RB10
                                                                                              SW5
                                                                           SW5
                                                                                      10K R37
#define SW7 PORTBbits.RB9
                                                                                              SW6
                                                                                    R39 10K R40 SW7
                                                                                  SW7 0 4.7K
                                                                                           4.7K
                                                                                            TRIG_2
```

```
#include <xc.h>
/*standard "pragma config's" in here... */
void main() {
  //init starts *******
  TRISFbits.TRISF3 = 1;
                                                 את switch מגדירים לכל פורט של*
  TRISFbits.TRISF5 = 1;
                                              הRIST להיות 1 כי הוא PORT כניסה.
  TRISFbits.TRISF4 = 1;
  TRISDbits.TRISD15 = 1;
                                                   TRISFbits.TRISF3 = 1 :ע"יי *
  TRISDbits.TRISD14 = 1;
  TRISBbits.TRISB11 = 1;
  TRISBbits.TRISB10 = 1;
  TRISBbits.TRISB9 = 1;
                                            *פורטי כניסה מסויימים ניתן להגדיר כאנלוגיים ולא
  ANSELBbits.ANSB11 = 0;//SW5 an disable
                                                       כדיגיטליים (0/1 כלומר דלוק\כבוי).
  ANSELBbits.ANSB10 = 0;//SW6 an disable
                                                להיות sw5,sw6,sw7 להיות נגדיר את הפורטים
  ANSELBbits.ANSB9 = 0; //SW7 an disable
                                               שלהם. Analog disable שלהם ע"י ביצוע
  //init ends ********
                                              מטרול ע"י: ANSELBbits.ANSB9 = 0
  while (1) {
                                                  *כאן כל כפתור מדליק\מכבה את הלד
    PORTAbits.RA0 = PORTFbits.RF3;
                                                    המתאים לו (שנמצא פיזית מעליו).
    PORTAbits.RA1 = PORTFbits.RF5;
    PORTAbits.RA2 = PORTFbits.RF4;
    PORTAbits.RA3 = PORTDbits.RD15;
    PORTAbits.RA4 = PORTDbits.RD14;
    PORTAbits.RA5 = PORTBbits.RB11;
    PORTAbits.RA6 = PORTBbits.RB10;
    PORTAbits.RA7 = PORTBbits.RB9;
  }
```

### **User Buttons**

| Description | PIC32 pin                 | Pin Shared<br>With | Schem' name  | Label        |
|-------------|---------------------------|--------------------|--------------|--------------|
| Left        | PGED1/ANO/RPB0/RBO        | PGD                | BTN <b>L</b> | BTNL         |
| Right       | AN8/RPB8/CTED10/RB8       | S0_PWM             | BTN <b>R</b> | BTN <b>R</b> |
| Center      | RPF0/PMD11/RF0            | TRIG_1             | BTNC         | BTNC         |
| Up          | PGEC1/AN1/RPB1/CTED12/RB1 | PGC                | BTN <b>U</b> | BTN <b>U</b> |
| Down        | RPA15/ <b>RA15</b>        | S1_PWM             | BTN <b>D</b> | BTN <b>D</b> |

### Ports Macro's:

#define tris\_BTNL TRISBbits.TRISB0
#define ansel\_BTNL ANSELBbits.ANSB0
#define prt\_BTNL PORTBbits.RB0

#define tris\_BTNR TRISBbits.TRISB8
#define ansel\_BTNR ANSELBbits.ANSB8
#define prt\_BTNR PORTBbits.RB8

#define tris\_BTNC TRISFbits.TRISFO #define prt BTNC PORTFbits.RFO

#define tris\_BTNU TRISBbits.TRISB1
#define ansel\_BTNU ANSELBbits.ANSB1
#define prt\_BTNU PORTBbits.RB1

#define tris\_BTND TRISAbits.TRISA15
#define prt\_BTND PORTAbits.RA15



```
#include <xc.h>
/*standard "pragma config's" in here... */
/*User Buttons defines and prototypes*/
#define tris BTNL TRISBbits.TRISB0
#define ansel BTNL ANSELBbits.ANSB0
#define prt BTNL PORTBbits.RB0
#define tris BTNR TRISBbits.TRISB8
#define ansel BTNR ANSELBbits.ANSB8
#define prt BTNR PORTBbits.RB8
#define tris_BTNC TRISFbits.TRISF0
#define prt_BTNC PORTFbits.RF0
#define tris BTNU TRISBbits.TRISB1
#define ansel BTNU ANSELBbits.ANSB1
#define prt BTNU PORTBbits.RB1
#define tris BTND TRISAbits.TRISA15
#define prt BTND PORTAbits.RA15
void delay();
/*LCD defines and prototypes*/
void busy(void);
void initLCD();
#define DISP EXEC PORTDbits.RD4 = 1;PORTDbits.RD4 = 0;busy();
void main() {
 /*Init User Buttons*/
 tris BTNU = 1;
 tris BTNL = 1;
 tris BTNC = 1;
 tris BTNR = 1;
 tris BTND = 1;
 ansel BTNU = 0;
 ansel_BTNL = 0;
 ansel BTNR = 0;
 /*LCD*/
  initLCD();
 PORTBbits.RB15 = 0; //command mode
 PORTE = 0x1;
 DISP EXEC
 PORTBbits.RB15 = 1; //data mode
```

```
char btn_name = '_';
  int counter = 0;
  while (1) {
        while (1) {
              if (prt BTNL) {
                btn name = 'L';
                break;
              else if (prt BTNR) {
                btn name = 'R';
                break;
              else if (prt BTNC) {
                btn name = 'C';
                break;
              else if (prt BTNU) {
                btn name = 'U';
                break;
              else if (prt_BTND) {
                btn name = 'D';
                break;
              }
        }
        PORTE = btn name;
        DISP EXEC
        delay();
        counter++;
        if (counter == 16) {
          PORTBbits.RB15 = 0; //command mode
          PORTE = 0xc0; //write to second line
          DISP EXEC
          PORTBbits.RB15 = 1; //data mode
        if (counter == 32) {
          PORTBbits.RB15 = 0; //command mode
          PORTE = 0x1; //flush LCD and write in first line
          DISP EXEC
          PORTBbits.RB15 = 1; //data mode
          counter = 0;
        }
    }
}
void delay() {
  int i;
  for (i = 0; i < 64000; i++); for (i = 0; i < 64000; i++);
  for (i = 0; i < 64000; i++); for (i = 0; i < 64000; i++);
  for (i = 0; i < 64000; i++); for (i = 0; i < 64000; i++);
```

## **RGB Leds**

| PIC32 pin        | Schem' name | Label |
|------------------|-------------|-------|
| AN25/RPD2/RD2    | LED8_R      | R     |
| RPD12/PMD12/RD12 | LED8_G      | G     |
| AN26/RPD3/       | LED8_B      | В     |



```
#define RGB_R PORTDbits.RD2
#define RGB_G PORTDbits.RD12
#define RGB B PORTDbits.RD3
```

```
#include <stdio.h>
/*standard "pragma config's" in here...*/
void main() {
  TRISFbits.TRISF3 = 1;
                                                  .sw0,sw1,sw2 פורטים כניסה
  TRISFbits.TRISF5 = 1;
  TRISFbits.TRISF4 = 1;
  //init starts *******
  TRISDbits.TRISD2 = 0;
                                            פורטים LED8_R, LED8_G, LED8_B
  TRISDbits.TRISD12 = 0;
  TRISDbits.TRISD3 = 0;
  ANSELDbits.ANSD2 = 0;
                                            פורטים דיגיטליים. LED8_R, LED8_B
  ANSELDbits.ANSD3 = 0;
  //init ends ********
                                                       sw0* מקושר לr
 while (1) {
                                                    sw1* מדליק∖מכבה sw1*
    PORTDbits.RD2 = PORTFbits.RF3;
                                                    sw2* מדליק\מכבה
    PORTDbits.RD12 = PORTFbits.RF5;
    PORTDbits.RD3 = PORTFbits.RF4;
  }
```

## **Speaker**





כדי שספיקר יפעל צריך לתת לתת מתח\להפסיק מתח כל 640 פעולות (זה מה שיוצר רטט ברכיב הספיקר מה שמוציא סאונד).

#### צפצוף אחיד:

```
#include <stdio.h>
/*standard "pragma config's" in here... */

void main() {
    //init starts*********
    TRISBbits.TRISB14 = 0; //Speaker - as output
    ANSELBbits.ANSB14 = 0; //Speaker - disabled Analog
    //init ends**********

    int i=0;
    PORTBbits.RB14 = 0;

while(1) {
        if(i%640==0)
            PORTBbits.RB14 = !PORTBbits.RB14;
        i++;
        }
    }
}
```

#### צפצוף לסירוגין:

```
#include <stdio.h>
/*standard "pragma config's" in here... */
void main() {
    //init starts********
    TRISBbits.TRISB14 = 0; //Speaker - as output
    ANSELBbits.ANSB14 = 0; //Speaker - disabled analog
    //init ends*********
    int i;
    PORTBbits.RB14 = 0;
    while(1){
        for (i=0;i<640000;i++);</pre>
        for (i=0;i<640000;i++) {</pre>
            if(i%640==0)
                 PORTBbits.RB14 = !PORTBbits.RB14;
        }
    }
```

## **LCD**

| Name    | PIN32 Pin                       | Description                                              |
|---------|---------------------------------|----------------------------------------------------------|
| DISP_RS | AN15/RPB15/OCFB/CTED6/PMA0/RB15 | <b>0</b> for command, <b>1</b> for data (inside DB0-DB7) |
| DISP_RW | RPD5/PMRD/RD5                   | 1 for Read ,0 for Write (from/to DB0-DB7)                |
| DISP_EN | RPD4/PMWR/RD4                   | signal (1 and then 0)                                    |
| DB0     | PMD0/RE0                        | DB0-DB7 (PORTE)                                          |
| DB1     | PMD1/RE1                        |                                                          |
| DB2     | AN20/PMD2/RE2                   |                                                          |
| DB3     | RPE3/CTPLS/PMD3/RE3             |                                                          |
| DB4     | AN21/PMD4/RE4                   |                                                          |
| DB5     | AN22/RPE5/PMD5/RE5              |                                                          |
| DB6     | AN23/PMD6/RE6                   |                                                          |
| DB7     | AN27/PMD7/RE7                   |                                                          |





## <u>הסבר:</u>

1. תחילה נבצע את הפקודות: (מתבצע בפונקציית <u>initLCD</u>)

TRISE &= 0xff00;

PORTDbits.RD5 = 0; // DISP\_RW is Write

שמגדירה את DB0-DB7 כיציאות שאליהן אנחנו כותבים.

2. נבצע את הפקודה:

PORTBbits.RB15 = 0;

כדי להבהיר שהמידע שאנחנו **כותבים** לפורטים DB0-DB7 הוא פעולה שאנחנו רוצים שהמסך יבצע.

## פעולות נפוצות:

בשורה הראשונה של המסך. 0x1 = 0x1

תחילת כתיבה בשורה הראשונה של המסך. 0x80

0xc0 = תחילת כתיבה <u>בשורה השניה</u> של המסך.

פעמים באיתחול המסך). (צריך לבצע 3 פעמים באיתחול המסך). (בצע את הפקודה: 3 PORTBbits.RB15 = 1; רבצע את הפקודה מדי להבהיר שהמידע שאנחנו כותבים לפורטים PORTE) DB0-DB7 הוא תו שאנחנו כותבים לפורטים ידפיס.

1. לבצע את הפקודות: 4 //signal PORTDbits.RD4=1; PORTDbits.RD4=0; busy();

כאשר אנו רוצים שהמסך יבצע את הפעולה שכתבנו לפורטי הדאטה או שאנו רוצים

שהמסך ידפיס תו שכתבנו לפורטי הדאטה.

| Shahar |  |
|--------|--|
| Hikri_ |  |

```
#include <xc.h>
#include <string.h>
/*standard "pragma config's" in here... */
void busy(void); void initLCD();
void main() {
   char* line1 = "Shahar";
    char* line2 = "Hikri";
   int i;
   initLCD();
    /*PRINT TO 1'ST LINE*/
    /*command mode*/
    PORTBbits.RB15 = 0;
    /*flush LCD and print to 1'st line command execute*/
    PORTE = 0x1;
    //execute command
    PORTDbits.RD4 = 1;
    PORTDbits.RD4 = 0;
   busy();
    /*data mode*/
    PORTBbits.RB15 = 1;
    /*print line1 = "Shahar"*/
    for(i=0;i<strlen(line1);i++){</pre>
        PORTE=line1[i];
        //print char
        PORTDbits.RD4 = 1;
        PORTDbits.RD4 = 0;
        busy();
    /*PRINT TO 2'ND LINE*/
    /*command mode*/
    PORTBbits.RB15 = 0;
    /*flush LCD and print to 1'st line command execute*/
    PORTE = 0xc0;
    //execute command
    PORTDbits.RD4 = 1;
    PORTDbits.RD4 = 0;
   busy();
    /*data mode*/
    PORTBbits.RB15 = 1;
    /*print line2 = "Hikri"*/
    for(i=0;i<strlen(line2);i++){</pre>
        PORTE=line2[i];
        //print char
        PORTDbits.RD4 = 1;
        PORTDbits.RD4 = 0;
        busy();
    }
```

```
void busy(void) {
  char RD = PORTDbits.RD5;
  char RS = PORTBbits.RB15;
  int STATUS TRISE = TRISE;
  PORTBbits.RB15 = 0; //Command mode
  PORTDbits.RD5 = 1; //Read mode (from DB0-DB7)
  //DB7 Tris set to input (BF register)
  TRISE |= 0x80;
  do {
   PORTDbits.RD4 = 1; //enable=1
   PORTDbits.RD4 = 0; //enable=0
  while (PORTEbits.RE7); // (DB7) BF register
  PORTDbits.RD5 = RD;
 PORTBbits.RB15 = RS;
 TRISE = STATUS TRISE;
void initLCD() {
  char control[] = \{0x38, 0x38, 0x38, 0xe, 0x6, 0x1\};
  //init DISP RS DISP RW DISP EN
 TRISBbits.TRISB15 = 0; // DISP RS (RB15) as Output
  ANSELBbits.ANSB15 = 0; // DISP RS (RB15) disable analog
  TRISDbits.TRISD5 = 0; // DISP RW (RD5) set as an Output
 TRISDbits.TRISD4 = 0; // DISP EN (RD4) set as an Output
  //init DB0-DB7
  TRISE &= 0xff00;
 ANSELEbits.ANSE2 = 0;
 ANSELEbits.ANSE4 = 0;
 ANSELEbits.ANSE5 = 0;
 ANSELEbits.ANSE6 = 0;
 ANSELEbits.ANSE7 = 0;
  PORTBbits.RB15 = 0; //rs=0 (Command)
  PORTDbits.RD5 = 0; //w=0 (Write into )
  for (i = 0; i < 6; i++) {
   PORTE = control[i];
    //signal
    PORTDbits.RD4 = 1;
    PORTDbits.RD4 = 0;
   busy();
  }
```

רגיסטר ה-BF – לאחר שהמידע נקרא מdb0-db7 אז הdb7 הופך להיות הBF – לאחר שהמידע נקרא מdb0-db7 אז הb7 – BF – לאחר שהמידע נקרא מלומר כאשר הוא 1 המסך כרגע מעבד את המידע ומבצע את הפעולה\מדפיס תו. לכן רק שהFF שהBF יורד ל0 ניתן לעשות פעולה חדשה\להדפיס תו נוסף על המסך. (מופיע בפונקציה (Busy).

## <u>הוספת תווים שלא קיימים</u>

האוכסנים בזיכרון זה. ASCII (כמעט כל – CGROM

שמכיל תווים שאנחנו יוצרים. יצירת תו הינה מערך של char-ים שכל – CGRAM – זיכרון שמכיל תווים שאנחנו יוצרים. יצירת חו הינה מערך של ביט כבוי הוא פיקסל אחד מהם מייצג שורה בהתאמה, כל ביט דלוק בו הוא פיקסל דלוק וכל ביט כבוי הוא פיקסל כבוי.

- צורבים לCGRAM את התו בעזרת הפעולה •
- עד 8 תווים חדשים ו"קוד הASCII" שלהם בבקר יהיו מ0 עד CGRAM (לאחסן ב במקר יהיו מ0 עד 8 בהתאם לסדר צריבתם.

דוגמא לצריבת התווים 'ש','ת' והדפסת:



```
#include <xc.h>
/*standard "pragma config's" in here... */
void busy(void);
void initLCD();
#define DISP EXEC
                      PORTDbits.RD4 = 1; PORTDbits.RD4 = 0; busy();
void main() {
    initLCD();
   char CG_{shin[8]} = \{0b10101,
                     0b10101,
                     0b10101,
                     0b10101,
                     0b10101.
                     0b10101,
                     0b10101,
                     0b11111};
   char CG_taf[8] = { 0b01111,
                     0b01001,
                     0b01001,
                     0b01001.
                     0b01001.
                     0b01001,
                     0b01001,
                     0b11001};
    char shin = 0;
    char taf = 1;
    PORTBbits.RB15 = 0;//COMMAND mode
    PORTE=0 \times 40;
                       //Add char's to CDRAM
    DISP EXEC
    PORTBbits.RB15 = 1;//DATA
    /*Write char's to CDRAM*/
    int i;
    for(i = 0;i < 8;i++){ //writing 'W' to CGRAM</pre>
         PORTE=CG shin[i];
         DISP EXEC
    for (i = 0; i < 8; i++) {//writing 'n' to CGRAM
         PORTE=CG taf[i];
         DISP EXEC
```

```
/*Print 'nwsT'*/
PORTBbits.RB15 = 0; //COMMAND mode
PORTE=0x80; //Write in 1'st line command
DISP_EXEC

/*data mode*/
PORTBbits.RB15 = 1;
PORTE=taf;
DISP_EXEC

PORTE=shin;
DISP_EXEC

PORTE='T';
DISP_EXEC

PORTE='T';
DISP_EXEC

PORTE='S';
DISP_EXEC
```

|                                  |                   |              |                                                                                      |                                                                                                          | C                                                                     | ode                   |        |     |     |     | _                                                                                                                                                                                     | Execution Time (max) (when f <sub>cp</sub> or                                           |
|----------------------------------|-------------------|--------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------|--------|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| Instruction                      | RS                | R/W          | DB7                                                                                  | DB6                                                                                                      | DB5                                                                   | DB4                   | DB3    | DB2 | DB1 | DB0 | Description                                                                                                                                                                           | f <sub>osc</sub> is 270 kHz)                                                            |
| Clear<br>display                 | 0                 | 0            | 0                                                                                    | 0                                                                                                        | 0                                                                     | 0                     | 0      | 0   | 0   | 1   | Clears entire display and sets<br>DDRAM address 0 in address<br>counter.                                                                                                              |                                                                                         |
| Return<br>home                   | 0                 | 0            | 0                                                                                    | 0                                                                                                        | 0                                                                     | 0                     | 0      | 0   | 1   | _   | Sets DDRAM address 0 in<br>address counter. Also returns<br>display from being shifted to<br>original position. DDRAM<br>contents remain unchanged.                                   | 1.52 ms                                                                                 |
| Entry<br>mode set                | 0                 | 0            | 0                                                                                    | 0                                                                                                        | 0                                                                     | 0                     | 0      | 1   | I/D | S   | Sets cursor move direction<br>and specifies display shift.<br>These operations are<br>performed during data write<br>and read.                                                        | 37 μs                                                                                   |
| Display<br>on/off<br>control     | 0                 | 0            | 0                                                                                    | 0                                                                                                        | 0                                                                     | 0                     | 1      | D   | С   | В   | Sets entire display (D) on/off,<br>cursor on/off (C), and blinking<br>of cursor position character<br>(B).                                                                            | 37 µs                                                                                   |
| Cursor or<br>display<br>shift    | 0                 | 0            | 0                                                                                    | 0                                                                                                        | 0                                                                     | 1                     | S/C    | R/L | _   | _   | Moves cursor and shifts display without changing DDRAM contents.                                                                                                                      | 37 μs                                                                                   |
| Function<br>set                  | 0                 | 0            | 0                                                                                    | 0                                                                                                        | 1                                                                     | DL                    | Ν      | F   | _   | _   | Sets interface data length (DL), number of display lines (N), and character font (F).                                                                                                 | 37 µs                                                                                   |
| Set<br>CGRAM<br>address          | 0                 | 0            | 0                                                                                    | 1                                                                                                        | ACG                                                                   | ACG                   | ACG    | ACG | ACG | ACG | Sets CGRAM address. CGRAM data is sent and received after this setting.                                                                                                               | 37 µs                                                                                   |
| Set<br>DDRAM<br>address          | 0                 | 0            | 1                                                                                    | ADD                                                                                                      | ADD                                                                   | ADD                   | ADD    | ADD | ADD | ADD | Sets DDRAM address.<br>DDRAM data is sent and<br>received after this setting.                                                                                                         | 37 μs                                                                                   |
| Read busy<br>flag &<br>address   | 0                 | 1            | BF                                                                                   | AC                                                                                                       | AC                                                                    | AC                    | AC     | AC  | AC  | AC  | Reads busy flag (BF)<br>indicating internal operation is<br>being performed and reads<br>address counter contents.                                                                    | 0 µs                                                                                    |
|                                  |                   |              |                                                                                      |                                                                                                          | Co                                                                    | ode                   |        |     |     |     |                                                                                                                                                                                       | Execution Time (max) (when f <sub>cp</sub> c                                            |
| Instruction                      | RS                | R/W          | DB7                                                                                  | DB6                                                                                                      | DB5                                                                   | DB4                   | DB3    | DB2 | DB1 | DB0 | Description                                                                                                                                                                           | f <sub>osc</sub> is 270 kHz)                                                            |
| Write data<br>to CG or<br>DDRAM  | 1                 | 0            | Write                                                                                | data                                                                                                     |                                                                       |                       |        |     |     |     | Writes data into DDRAM or CGRAM.                                                                                                                                                      | $37 \mu s$<br>$t_{ADD} = 4 \mu s^*$                                                     |
| Read data<br>from CG or<br>DDRAM | 1                 | 1            | Read                                                                                 | d data                                                                                                   |                                                                       |                       |        |     |     |     | Reads data from DDRAM or CGRAM.                                                                                                                                                       | $37 \mu s$<br>$t_{ADD} = 4 \mu s^*$                                                     |
|                                  | S/C<br>R/L<br>R/L | = 1:<br>= 1: | Decr<br>Acco<br>Disp<br>Curs<br>Shift<br>Shift<br>8 bits<br>2 line<br>5 × 1<br>Inter | ment<br>ement<br>mpan<br>lay shi<br>or mo<br>to the<br>to the<br>s, DL =<br>es, N =<br>0 dots<br>nally o | ies dis<br>ift<br>ve<br>right<br>left<br>= 0: 4<br>= 0: 1<br>s, F = 0 | bits<br>line<br>D: 5× | 8 dots |     |     |     | DDRAM: Display data RAM CGRAM: Character generator RAM ACG: CGRAM address ADD: DDRAM address (corresponds to cursor address) AC: Address counter used for both DD and CGRAM addresses | frequency change<br>Example:<br>When f <sub>op</sub> or f <sub>osc</sub> is<br>250 kHz, |

# מקלדת (Pull Up<u>)</u>

| Pmod pin | Schematic Label | PIC32 pin                     | Description |
|----------|-----------------|-------------------------------|-------------|
|          |                 |                               |             |
| PMODA_1  | JA_1            | RPC2/RC2                      | X0          |
| PMODA_2  | JA_2            | RPC1/RC1                      | X1          |
| PMODA_3  | JA_3            | RPC4/CTED7/RC4                | X2          |
| PMODA_4  | JA_4            | AN16/C1IND/RPG6/SCK2/PMA5/RG6 | X3          |
| PMODA_7  | JA_7            | RPC3/RC3                      | Y0          |
| PMODA_8  | JA_8            | AN17/C1INC/RPG7/PMA4/RG7      | Y1          |
| PMODA_9  | JA_9            | AN18/C2IND/RPG8/PMA3/RG8      | Y2          |
| PMODA_10 | JA_10           | AN19/C2INC/RPG9/PMA2/RG9      | Y3          |

צים – פורטים **יציאה** (אותם משנים בקוד - מכבים לשם הבדיקה ואז מדליקים חזרה).

Y-ים – פורטים **כניסה** (אותם בודקים בקוד – אם כבויים).

## בדיקה האם כפתור נלחץ:

כאשר רוצים לבדוק האם הכפתור ב(X1,Y2) (הכפתור '6') נלחץ:

נכבה את X0.

נלחץ). (X1,Y2) כבוי (אם כן אז הכפתור ב

נדליק חזרה את X0.



```
#define X0 PORTCbits.RC2
#define X1 PORTCbits.RC1
#define X2 PORTCbits.RC4
#define X3 PORTGbits.RG6
#define Y0 PORTCbits.RC3
#define Y1 PORTGbits.RG7
#define Y2 PORTGbits.RG8
#define Y3 PORTGbits.RG9
/*Left digit represents the X number
 Right digit represents te Y number*/
int getPressedKbBtn(){
   X0=1; X1=1; X2=1; X3=1;
   X0 = 0;
   if(!Y0)
       return 00;
    if(!Y1)
       return 01;
    if(!Y2)
       return 02;
    if(!Y3)
       return 03;
    X0 = 1;
   X1 = 0;
    if(!Y0)
        return 10;
    if(!Y1)
        return 11;
    if(!Y2)
        return 12;
    if(!Y3)
        return 13;
   X1=1;
   X2 = 0;
    if(!Y0)
        return 20;
    if(!Y1)
        return 21;
    if(!Y2)
        return 22;
    if(!Y3)
        return 23;
    X2=1;
   X3=0;
    if(!Y0)
        return 30;
    if(!Y1)
        return 31;
    if(!Y2)
        return 32;
    if(!Y3)
        return 33;
    X3=1;
    return -1;
```

```
void initKeyBoard(){
    /* X's init */
   TRISCbits.TRISC2=0;//X0 (RC2) as Output
   TRISCbits.TRISC1=0;//X1 (RC1) as Output
   TRISCbits.TRISC4=0;//X2 (RC4) as Output
   TRISGbits.TRISG6=0;//X3 (RG6) as Output
   ANSELGbits.ANSG6=0;//
                             disable Anaglog
   X0=1; X1=1; X2=1; X3=1;
    /* Y's init */
   TRISCbits.TRISC3 =1;//Y0 (RC3) as Input
   CNPUCbits.CNPUC3; //Pull Up Resistor enable
   TRISGbits.TRISG7=1;//Y1 (RG7) as Input
   ANSELGbits.ANSG7=0;
   CNPUGbits.CNPUG7;
   TRISGbits.TRISG8=1;//Y2 (RG8) as Input
   ANSELGbits.ANSG8=0;
   CNPUGbits.CNPUG8;
   TRISGbits.TRISG9=1;//Y3 (RG9) as Input
   ANSELGbits.ANSG9=0;
   CNPUGbits.CNPUG9;
```

#### <u>השהיות בין הלחיצות כדי לקבל לחיצה בודדת:</u>

בין בדיקה לבדיקה (בדיקה = איזה מקש נלחץ ~ הפעלת פונ' ()getPressedBtn) בין בדיקה לבדיקה (בדיקה = איזה מקש נלחץ

```
for(i=0;i<64000;i++);

for(i=0;i<64000;i++);

for(i=0;i<64000;i++);

for(i=0;i<64000;i++);

for(i=0;i<64000;i++);
```

(לדוגמא שרוצים להדפיס על המסך את התו המייצג את המקש שנלחץ – אם לא נשים השהיה בין הלחיצות יודפס למסך כמה פעמים עבור כל לחיצה).

```
void initKeyBoard(); int in_y(int a);
/* תוכנית שמדפיסה על הלדים את המספר של הכפתור שנלחץ בייצוג בינארי
void main(void) {
 TRISA&=0xff00;//led
  initKeyBoard();
  char scan key[] = {
  // XY
    0x44, 1, //0b 0100 0100
    0x34, 2, //0b 0011 0100
    0x24, 3, //0b 0010 0100
    0x43, 4, //0b 0100 0100
0x33, 5, //0b 0100 0100
    0x23, 6, //0b 0100 0100

0x42, 7, //0b 0100 0100

0x32, 8, //0b 0100 0100

0x22, 9, //0b 0100 0100

0x41, 0 //0b 0100 0100
  };
  int i, xy;
  while (1) {
    while (1) {
      i = 1;
      PORTCbits.RC2 = 1;
      PORTCbits.RC1 = 1;
      PORTCbits.RC4 = 1;
      PORTGbits.RG6 = 1;
      i = 1;
      PORTCbits.RC2 = 0;
      xy = in y(1);
      if (xy != 0xff)
        break;
      PORTCbits.RC2 = 1;
       i = 2;
      PORTCbits.RC1 = 0;
      xy = in y(2);
      if (xy != 0xff)
        break;
      PORTCbits.RC1 = 1;
       i = 3;
      PORTCbits.RC4 = 0;
      xy = in y(3);
      if (xy = 0xff)
        break;
      PORTCbits.RC4 = 1;
       i = 4;
      PORTGbits.RG6 = 0;
      xy = in y(4);
      if (xy != 0xff)
         break;
       PORTGbits.RG6 = 1;
    for (i = 0; i < 20; i += 2)
       if (scan key[i] == xy)
         PORTA = scan key[i + 1];
```

```
int in_y(int a) {
  int j = 1, flag = 0;
  if (!PORTCbits.RC3) {
    flag = 1;
    j = 1;
  } else if (!PORTGbits.RG7) {
    flag = 1;
    j = 2;
  } else if (!PORTGbits.RG8) {
    flag = 1;
    j = 3;
  } else if (!PORTGbits.RG9) {
    flag = 1;
    j = 4;
  if (flag == 0)
    return (0xff);
  else
    return (j | (a << 4));</pre>
```

## **ADC (Analog to Digital)**

רכיב אשר **מקבל** מתח מכניסה (אנלוגית) נבחרת מ ANO - AN15.

• כל כניסה ANi מחוברת ליציאה •

מחזיר מספר בעל 10 ביט (0-1024) המייצג את המתח שקיבל.

#### <u>לדוגמא:</u>

הכניסה הנבחרת AN2 שהמתח בה נע בין 0v ל<3.3v

אם המתח שנדגם בכניסה AN2(שמחוברת ליציאה RB2) הוא 2V

$$\frac{2v}{3.3v-0v}$$
 \* 1024 = **621** :אז יחזיר

float V = (((float)ADC\_AnalogRead(2)) / 1023) \* 3.3; : המרה בקוד

לפני ההפעלה צריך להפעיל את האנלוג:

TRISBbits.TRISB2 = 1;
ANSELBbits.ANSB2 = 1;



#### התהליך שהADC מבצע:

- 1. דגימה(Sampling) דוגם את המתח ביציאה הנבחרת.
- . מבצעים להתחלת את הדגימה AD1CON1bits.SAMP = 1
- (ואז ההמרה מתחילה אוטומטית) AD1CON1bits.SAMP is 0  $^{*}$
- 2. **המרה(Conversion)** ממיר את המתח למספר מייצג (בגודל 10-ביט) שאותו שם על הרגיסטר ASVBUFO.
  - cאשר מתחילה ההמרה. AD1CON1bits.DONE is 0
  - AD1CON1bits.DONE is 1 כאשר מסתיימת ההמרה ההמרה.
- \* AD1CON3 הערך בו קובע את משך זמן ההמרה (המקסימלי), ככל שיהיה משך זמן גדול יותר אז יהיו פחות שגיאות אך ההמרה תיקח יותר זמן.

```
void ADC Init(){
   AD1CON1 =0;
   AD1CON1bits.SSRC = 7; //Auto convert (after sampeling)
   AD1CON1bits.FORM = 0; //16 bit integer result
   // Setup for manual sampling
   AD1CSSL =0;
   AD1CON3 = 0 \times 0002; //ADC Conversion Clock
   AD1CON2 =0;
   AD1CON2bits.VCFG = 0;
   // Turn on ADC
   AD1CON1bits.ON = \frac{1}{2}; //ADC on (activate)
}
unsigned int ADC AnalogRead (unsigned char analogPIN) {
   int adc val = 0;
   //IECObits.T2IE = 0;
   AD1CHS = analogPIN << 16; // AD1CHS<16:19> controls which
                                 //analog pin goes to the ADC
   adc val = ADC1BUF0;
   //IECObits.T2IE = 1;
   return adc val;
}
```

| Virtual<br>Address | Name       |       | Bit<br>31/23/15/7 | Bit<br>30/22/14/6 | Bit<br>29/21/13/5 | Bit<br>28/20/12/4 | Bit<br>27/19/11/3 | Bit<br>26/18/10/2 | Bit<br>25/17/9/1 | Bit<br>24/16/8/0 |
|--------------------|------------|-------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| BF80_9000          | AD1CON1    | 31:24 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 23:16 | _                 | _                 | -                 | _                 | -                 | _                 | _                | _                |
|                    |            | 15:8  | ON                | FRZ               | SIDL              | _                 | -                 | FORM2             | FORM1            | FORM0            |
|                    |            | 7:0   | SSRC2             | SSRC1             | SSRC0             | CLRASAM           | _                 | ASAM              | SAMP             | DONE             |
| BF80_9004          | AD1CON1CLR | 31:0  |                   | Write             | clears selected   | bits in AD1C0     | DN1, read yield   | s undefined va    | alue             |                  |
| BF80_9008          | AD1CON1SET | 31:0  |                   | Write             | sets selected     | bits in AD1CO     | N1, read yields   | s undefined val   | lue              |                  |
| BF80_900C          | AD1CON1INV | 31:0  |                   | Write             | inverts selecte   | d bits in AD1C    | ON1, read yiek    | ds undefined v    | alue             |                  |
| BF80_9010          | AD1CON2    | 31:24 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 23:16 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 15:8  | VCFG2             | VCFG1             | VCFG0             | OFFCAL            | _                 | CSCNA             | _                | _                |
|                    |            | 7:0   | BUFS              | _                 | SMPI3             | SMPI2             | SMPI1             | SMPI0             | BUFM             | ALTS             |
| BF80_9014          | AD1CON2CLR | 31:0  |                   | Write             | clears selected   | bits in AD1C0     | DN2, read yield   | s undefined va    | alue             |                  |
| BF80_9018          | AD1CON2SET | 31:0  |                   | Write             | sets selected     | bits in AD1CO     | N2, read yields   | s undefined val   | lue              |                  |
| BF80_901C          | AD1CON2INV | 31:0  |                   | Write i           | inverts selecte   | d bits in AD1C    | ON2, read yield   | ds undefined v    | alue             |                  |
| BF80_9020          | AD1CON3    | 31:24 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 23:16 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 15:8  | ADRC              | _                 | _                 | SAMC4             | SAMC3             | SAMC2             | SAMC1            | SAMC0            |
|                    | ,          | 7:0   | ADCS7             | ADCS6             | ADCS5             | ADCS4             | ADCS3             | ADCS2             | ADCS1            | ADCS0            |
| BF80_9024          | AD1CON3CLR | 31:0  |                   | Write             | clears selected   | bits in AD1C0     | DN3, read yield   | ts undefined va   | alue             |                  |
| BF80_9028          | AD1CON3SET | 31:0  |                   | Write             | sets selected     | bits in AD1CO     | N3, read yields   | s undefined val   | lue              |                  |
| BF80_902C          | AD1CON3INV | 31:0  |                   | Write i           | inverts selecte   | d bits in AD1C    | ON3, read yield   | ds undefined v    | alue             |                  |
| BF80_9040          | AD1CHS     | 31:24 | CH0NB             | _                 | _                 | _                 | CH0SB3            | CH0SB2            | CH0SB1           | CH0SB0           |
|                    |            | 23:16 | CH0NA             | _                 | _                 | _                 | CH0SA3            | CH0SA2            | CH0SA1           | CH0SA0           |
|                    | '          | 15:8  | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 7:0   | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
| BF80_9044          | AD1CHSCLR  | 31:0  |                   | Write             | clears selecte    | d bits in AD1C    | HS, read yield:   | s undefined va    | lue              | •                |
| BF80_9048          | AD1CHSSET  | 31:0  |                   | Write             | e sets selected   | bits in AD1CH     | S, read yields    | undefined valu    | Je .             |                  |
| BF80_904C          | AD1CHSINV  | 31:0  |                   | Write             | inverts selecte   | d bits in AD10    | HS, read yield    | s undefined va    | lue              |                  |
| BF80_9060          | AD1PCFG    | 31:24 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    | ,          | 23:16 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 15:8  | PCFG15            | PCFG14            | PCFG13            | PCFG12            | PCFG11            | PCFG10            | PCFG9            | PCFG8            |
|                    |            | 7:0   | PCFG7             | PCFG6             | PCFG5             | PCFG4             | PCFG3             | PCFG2             | PCFG1            | PCFG0            |
| BF80_9064          | AD1PCFGCLR | 31:0  |                   | Write             | clears selected   | bits in AD1P0     | CFG, read yield   | ls undefined va   | alue             |                  |
| BF80_9068          | AD1PCFGSET | 31:0  |                   | Write             | sets selected     | bits in AD1PC     | FG, read yields   | s undefined val   | ue               |                  |
| BF80_906C          | AD1PCFGINV | 31:0  |                   | Write             | inverts selecte   | d bits in AD1P    | CFG, read yield   | ds undefined va   | alue             |                  |
| BF80_9050          | AD1CSSL    | 31:24 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 23:16 | _                 | _                 | _                 | _                 | _                 | _                 | _                | _                |
|                    |            | 15:8  | CSSL15            | CSSL14            | CSSL13            | CSSL12            | CSSL11            | CSSL10            | CSSL9            | CSSL8            |
|                    |            | 7:0   | CSSL7             | CSSL6             | CSSL5             | CSSL4             | CSSL3             | CSSL2             | CSSL1            | CSSL0            |

#### REGISTER 22-1: AD1CON1: ADC CONTROL REGISTER 1 (CONTINUED)

bit 4 CLRASAM: Stop Conversion Sequence bit (when the first A/D converter interrupt is generated)

1 = Stop conversions when the first ADC interrupt is generated. Hardware clears the ASAM bit when the ADC interrupt is generated. "פסיקות

= Normal operation, buffer contents will be overwritten by the next conversion sequence

bit 3 Reserved: Write 'o'; ignore read

bit 2 ASAM: ADC Sample Auto-Start bit

צורת הפעלה

1 = Sampling begins immediately after last conversion completes; SAMP bit is automatically set.

0 = Sampling begins when SAMP bit is set

bit 1 SAMP: ADC Sample Enable bit

אפשור דגימה

1 = The ADC SHA is sampling

The ADC sample/hold amplifier is holding
 When ASAM = 0, writing '1' to this bit starts sampling.

When SSRC = 000, writing '0' to this bit will end sampling and start conversion.

bit 0 DONE: A/D Conversion Status bit

1 = A/D conversion is done

דגל BUSY

a = A/D conversion is not done or has not started
 clearing this bit will not affect any operation in progress.

Note: The DONE bit is not persistent in automatic modes. It is cleared by hardware at the beginning of the next sample.

#### REGISTER 22-3: AD1CON3: ADC CONTROL REGISTER 3

| r-x    | r-x | r-x | r-x | r-x | r-x | r-x | r-x |
|--------|-----|-----|-----|-----|-----|-----|-----|
| _      | _   | _   | _   | _   | _   | _   | _   |
| bit 31 | _   | -   | -   |     |     |     | bit |

| r-x    | r-x | r-x | r-x | r-x | r-x | r-x | r-x |
|--------|-----|-----|-----|-----|-----|-----|-----|
| _      | _   | _   | _   | _   | _   | _   | _   |
| bit 23 |     |     |     |     |     |     | bit |

| R/W-0  | r-x | r-x | R/W-0 | R/W-0 | R/W-0     | R/W-0 | R/W-0 |
|--------|-----|-----|-------|-------|-----------|-------|-------|
| ADRC   | _   | _   |       |       | SAMC<4:0> |       |       |
| bit 15 |     |     |       |       |           |       | b     |

| R/W-0     | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |  |  |  |
|-----------|-------|-------|-------|-------|-------|-------|-------|--|--|--|
| ADCS<7:0> |       |       |       |       |       |       |       |  |  |  |
| bit 7     |       |       |       |       |       |       | b     |  |  |  |

Legend:

R = Readable bit W = Writable bit P = Programmable bit r = Reserved bit

U = Unimplemented bit -n = Bit Value at POR: ('0', '1', x = Unknown)

bit 31-16 Reserved: Write '0'; ignore read

bit 15 ADRC: ADC Conversion Clock Source bit

1 = ADC internal RC clock

0 = Clock derived from Peripheral Bus Clock (PBClock)

קצב המרה

bit 14-13 Reserved: Write '0'; ignore read bit 12-8 SAMC<4:0>: Auto-Sample Time bits

11111 = 31 TAD

00001 = 1 TAD 00000 = 0 TAD (Not allowed)

bit 7-0 ADCS<7:0>: ADC Conversion Clock Select bits

11111111 = TpB • (ADCS<7:0> + 1) • 2 = 512 • TpB = TaD

. . . . . .

00000001 = TpB • (ADCS<7:0> + 1) • 2 = 4 • TpB = TAD 00000000 = TpB • (ADCS<7:0> + 1) • 2 = 2 • TpB = TAD

|                            | 22-2: AD1C0                                                                                                                                                                                  | DN2: ADC CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ONTROL RE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | GISTER 2                                                                                                                                  |                                                                               |                                            |       |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------|-------|
| r-x                        | r-x                                                                                                                                                                                          | r-x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | r-x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | r-x                                                                                                                                       | r-x                                                                           | r-x                                        | r-x   |
| _                          |                                                                                                                                                                                              | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | _                                                                                                                                         | _                                                                             | _                                          | _     |
| bit 31                     |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                           |                                                                               |                                            | bit   |
|                            |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                           |                                                                               |                                            |       |
| r-x                        | r-x                                                                                                                                                                                          | r-x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | r-x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | r-x                                                                                                                                       | r-x                                                                           | r-x                                        | r-x   |
|                            |                                                                                                                                                                                              | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | _                                                                                                                                         | _                                                                             | _                                          | _     |
| bit 23                     |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                           |                                                                               |                                            | bit   |
|                            |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                           |                                                                               |                                            |       |
| R/W-0                      | R/W-0                                                                                                                                                                                        | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | r-x                                                                                                                                       | R/W-0                                                                         | r-x                                        | r-x   |
|                            | VCFG<2:0>                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | OFFCAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | _                                                                                                                                         | CSCNA                                                                         | _                                          |       |
| bit 15                     |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                           |                                                                               |                                            | bi    |
|                            |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                           | 544.0                                                                         | 5                                          |       |
| R-0                        | r-x                                                                                                                                                                                          | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W-0                                                                                                                                     | R/W-0                                                                         | R/W-0                                      | R/W-0 |
| BUFS                       | _                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SMP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1<3:0>                                                                                                                                    |                                                                               | BUFM                                       | ALTS  |
| bit 7                      |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                           |                                                                               |                                            | bi    |
| Legend:                    |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                           |                                                                               |                                            |       |
| R = Readable               | a hit                                                                                                                                                                                        | W = Writable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | P = Progran                                                                                                                               | nmable bit                                                                    | r = Reserved                               | hit   |
| U = Unimplen               |                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | at POR: ('0', '                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •                                                                                                                                         |                                                                               | i – iveserved                              | DIC   |
|                            | VCEG-2:05:                                                                                                                                                                                   | Voltage Pefere                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | nce Configure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | tion hite                                                                                                                                 |                                                                               |                                            |       |
| bit 15-13                  | VCFG<2:0>:                                                                                                                                                                                   | √oltage Refere                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | nce Configura                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                           | DC VR-                                                                        | ]                                          |       |
| DIL 10-13                  | VCFG<2:0>:                                                                                                                                                                                   | ADO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | A                                                                                                                                         | DC VR-                                                                        |                                            |       |
| DIL 19-13                  |                                                                                                                                                                                              | ADO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | VR+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | AI                                                                                                                                        |                                                                               |                                            |       |
| JIL 13*13                  | 000                                                                                                                                                                                          | ADC<br>AV<br>External                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VR+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | A                                                                                                                                         | AVss                                                                          |                                            |       |
| DIC 10-13                  | 000                                                                                                                                                                                          | ADO<br>A\<br>External                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VR+ /DD VREF+ pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | All Externa                                                                                                                               | AVss<br>AVss                                                                  |                                            |       |
| ык 13-13                   | 000<br>001<br>010                                                                                                                                                                            | ADC  A\ External  A\ External                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | VR+  /DD  VREF+ pin  /DD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Externa<br>Externa                                                                                                                        | AVss<br>AVss<br>al Vref- pin                                                  |                                            |       |
| bit 12                     | 000<br>001<br>010<br>011<br>1xx                                                                                                                                                              | ADC  A\ External  A\ External                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | VR+  VDD  VREF+ pin  VREF+ pin  VREF+ pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Externa<br>Externa                                                                                                                        | AVss<br>AVss<br>al VREF- pin<br>al VREF- pin<br>AVss                          |                                            |       |
|                            | 000<br>001<br>010<br>011<br>1xx<br>OFFCAL: Inp<br>1 = Enable Of<br>VINH and<br>0 = Disable O                                                                                                 | ADC  A\ External \ A\ External \ A\                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | VR+  /DD  VREF+ pin  /DD  VREF+ pin  /DD  ration Mode Sen mode A are connected mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Externa<br>Externa<br>Externa                                                                                                             | AVss AVss al VREF- pin al VREF- pin AVss OIN' NNY                             |                                            |       |
|                            | 000<br>001<br>010<br>011<br>1xx<br>OFFCAL: Inp<br>1 = Enable Of<br>VINH and<br>0 = Disable Of<br>The input                                                                                   | ADC  AV  External  AV  External  AV  ut Offset Calibration  VINL of the SHA  ffset Calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | VR+  /DD  VREF+ pin  /DD  VREF+ pin  /DD  ration Mode Sen mode A are connected in mode are controlled by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Externa<br>Externa<br>Externa                                                                                                             | AVss AVss al VREF- pin al VREF- pin AVss OIN' NNY                             |                                            |       |
| bit 12                     | 000 001 010 011 1xx  OFFCAL: Inp 1 = Enable Of VINH and 0 = Disable O The input  Reserved: W                                                                                                 | ADO  AVEXTERNAL  External  AVEXTERNAL  AVE | VR+ /DD VREF+ pin /DD VREF+ pin /DD ration Mode Sen mode A are connected in mode irre controlled by the controlled by th | External External External elect bit ad to VR-                                                                                            | AVSS AVSS al VREF- pin al VREF- pin AVSS OIN' NNY                             | _                                          | g bit |
| bit 12                     | O00 O01 O10 O11 1xx OFFCAL: Inp 1 = Enable Of VINH and 0 = Disable O The input Reserved: W CSCNA: Scar 1 = Scan input 0 = Do not sca                                                         | ADO  AVEXTERNAL  External  AVEXTERNAL  AVE | VR+ /DD VREF+ pin /DD VREF+ pin /DD ration Mode Sen mode A are connected are controlled by the constant of the | Externa Externa Externa elect bit ed to VR- y AD1CHS of                                                                                   | AVSS AVSS al VREF- pin al VREF- pin AVSS OIN' NNY                             | _                                          | g bit |
| bit 12<br>bit 11<br>bit 10 | 000 001 010 011 1xx  OFFCAL: Inp 1 = Enable Of VINH and 0 = Disable O The input Reserved: W CSCNA: Scar 1 = Scan input 0 = Do not scar Reserved: W BUFS: Buffer Only valid who 1 = ADC is cu | ADO  AV External  AV External  AV UIT Offset Calibration  VINL of the SHA Iffset Calibration  VINL of the SHA a rite '0'; ignore in Input Selection  an input Selection  is an inputs  Fill Status bit an BUFM = 1 (irrently filling bu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | VREF+ pin  VREF+ pin  VDD  VREF+ pin  VDD  ration Mode Sen mode A are connected are controlled by the  | External External External External elect bit ad to VR- y AD1CHS of GHA Input for GHA input for graph and action 2 x 8-word user should a | AVSS AVSS al VREF- pin al VREF- pin AVSS OIN' NNY.  T AD1CSSL MUX A Input Mul | itiplexer Setting<br>סטר תוצאו<br>סטר 2-00 |       |

ADACONO, ADO CONTROL DECICTED O

#### REGISTER 22-2: AD1CON2: ADC CONTROL REGISTER 2 (CONTINUED)

bit 5-2 SMPI<3:0>: Sample/Convert Sequences Per Interrupt Selection bits

פסיקות

1111 = Interrupts at the completion of conversion for each 16<sup>th</sup> sample/convert sequence

1110 = Interrupts at the completion of conversion for each 15<sup>th</sup> sample/convert sequence

0001 = Interrupts at the completion of conversion for each  $2^{\text{nd}}$  sample/convert sequence 0000 = Interrupts at the completion of conversion for each sample/convert sequence

bit 1 BUFM: ADC Result Buffer Mode Select bit

1 = Buffer configured as two 8-word buffers, ADC1BUF(7...0), ADC1BUF(15...8)

0 = Buffer configured as one 16-word buffer ADC1BUF(15...0.)

תוצאה

bit 0 ALTS: Alternate Input Sample Mode Select bit

> 1 = Uses MUX A input multiplexer settings for first sample, then alternates between MUX B and MUX A input multiplexer settings for all subsequent samples

0 = Always use MUX A input multiplexer settings

שימוש ב-MUX

#### REGISTER 22-4: AD1CHS: ADC INPUT SELECT REGISTER

| R/W-0  | г-х | Г-Х | r-x | R/W-0 | R/W-0 | R/W-0 | R/W-0  |
|--------|-----|-----|-----|-------|-------|-------|--------|
| CH0NB  | _   | _   | _   |       | CH0SE | <3:0> |        |
| bit 31 |     |     |     |       |       |       | bit 24 |

| R/W-0  | r-x | r-x | r-x | R/W-0 | R/W-0 | R/W-0 | R/W-0  |
|--------|-----|-----|-----|-------|-------|-------|--------|
| CH0NA  | _   | _   | _   |       | CH0SA | <3:0> |        |
| bit 23 |     |     |     |       |       |       | bit 16 |

| r-x    | r-x | Γ-X | r-x | r-x | r-x | r-x | г-х   |
|--------|-----|-----|-----|-----|-----|-----|-------|
| _      | _   | _   | _   | _   | _   | _   | _     |
| bit 15 |     |     |     |     |     |     | bit 8 |

| r-x   | r-x | r-x | r-x | r-x | r-x | r-x | r-x   |
|-------|-----|-----|-----|-----|-----|-----|-------|
| _     | _   | _   | _   | _   | _   | _   | _     |
| bit 7 |     |     |     |     |     |     | bit 0 |

Legend:

R = Readable bit W = Writable bit P = Programmable bit r = Reserved bit

U = Unimplemented bit -n = Bit Value at POR: ('0', '1', x = Unknown)

bit 31 CH0NB: Negative Input Select for MUX B bit

1 = Channel 0 negative input is AN1

0 = Channel 0 negative input is VR-

bit 30-28 Reserved: Write '0'; ignore read

bit 27-24 CH0SB<3:0>: Positive Input Select for MUX B bits

1111 = Channel 0 positive input is AN15 1110 = Channel 0 positive input is AN14

1101 = Channel 0 positive input is AN13

. . . . . .

0001 = Channel 0 positive input is AN1 0000 = Channel 0 positive input is AN0

bit 23 CHONA: Negative Input Select for MUX A Multiplexer Setting bit (2)

1 = Channel 0 negative input is AN1

0 = Channel 0 negative input is VR-

bit 22-20 Reserved: Write '0'; ignore read

bit 19-16 CH0SA<3:0>: Positive Input Select for MUX A Multiplexer Setting bits

1111 = Channel 0 positive input is AN15 1110 = Channel 0 positive input is AN14

1101 = Channel 0 positive input is AN13

. . . . . .

0001 = Channel 0 positive input is AN1 0000 = Channel 0 positive input is AN0

bit 15-0 Reserved: Write '0' ignore read

#### REGISTER 22-5: AD1PCFG: ADC PORT CONFIGURATION REGISTER

| r-0    | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | r-0    |
|--------|-----|-----|-----|-----|-----|-----|--------|
| _      | _   | _   | _   | _   | _   | _   | _      |
| bit 31 |     |     |     |     |     |     | bit 24 |

| r-0    | r-0 | r-0 | r-0 | r-0 | r-0 | r-0 | r-0    |
|--------|-----|-----|-----|-----|-----|-----|--------|
| _      | _   | _   | _   | _   | _   | -   | _      |
| bit 23 |     |     |     |     |     |     | bit 16 |

| R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0 | R/W-0 |
|--------|--------|--------|--------|--------|--------|-------|-------|
| PCFG15 | PCFG14 | PCFG13 | PCFG12 | PCFG11 | PCFG10 | PCFG9 | PCFG8 |
| bit 15 |        |        |        |        |        |       | bit 8 |

| R/W-0 | RW-0  | R/W-0 | R/W-0 | R/W-0 | R/W-0 | RW    | R/W-0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PCFG7 | PCFG6 | PCFG5 | PCFG4 | PCFG3 | PCFG2 | PCFG1 | PCFG0 |
| bit 7 | •     |       |       |       |       |       | bit 0 |

Legend:

R = Readable bit W = Writable bit P = Programmable bit r = Reserved bit

U = Unimplemented bit -n = Bit Value at POR: ('0', '1', x = Unknown)

bit 31-16 Reserved: Reserved for future use, maintain as '0'

bit 15-0 PCFG<15:0>: Analog Input Pin Configuration Control bits

- 1 = Analog input pin in Digital mode, port read input enabled, ADC input multiplexer input for this analog input connected to AVss
- 0 = Analog input pin in Analog mode, digital port read will return as a '1' without regard to the voltage on the pin, ADC samples pin voltage

# PIC32MX3XX/4XX

#### REGISTER 22-6: AD1CSSL: ADC INPUT SCAN SELECT REGISTER

| r-x    | r-x | r-x | r-x | r-x | r-x | r-x | r-x    |
|--------|-----|-----|-----|-----|-----|-----|--------|
| _      | _   | _   | _   | _   | _   | _   | _      |
| bit 31 |     |     |     |     |     |     | bit 24 |

| r-x    | r-x | r-x | r-x | r-x | r-x | r-x | r-x    |
|--------|-----|-----|-----|-----|-----|-----|--------|
| _      | _   | _   | _   | _   | _   | _   | _      |
| bit 23 |     |     |     |     |     |     | bit 16 |

| R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0 | R/W-0 |
|--------|--------|--------|--------|--------|--------|-------|-------|
| CSSL15 | CSSL14 | CSSL13 | CSSL12 | CSSL11 | CSSL10 | CSSL9 | CSSL8 |
| bit 15 |        |        |        |        |        |       | bit 8 |

| R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | RW    | R/W-0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| CSSL7 | CSSL6 | CSSL5 | CSSL4 | CSSL3 | CSSL2 | CSSL1 | CSSL0 |
| bit 7 |       |       |       |       |       |       |       |

Legend:

R = Readable bit W = Writable bit P = Programmable bit r = Reserved bit U = Unimplemented bit P = Bit Value at POR: ('0', '1', X = Unknown)

bit 31-16 Reserved: Write '0'

bit 15-0 CSSL<15:0>: ADC Input Pin Scan Selection bits

1 = Select ANx for input scan 0 = Skip ANx for input scan

TABLE 22-3: PINS ASSOCIATED WITH THE ADC MODULE

| Pin Name | Module<br>Control | Controlling Bit Field | Pin<br>Type | Buffer<br>Type | TRIS  | Description                |
|----------|-------------------|-----------------------|-------------|----------------|-------|----------------------------|
| AN0      | ON                | AD1PCFG<0>            | Α           | _              | Input | Analog Input               |
| AN1      | ON                | AD1PCFG<1>            | Α           | _              | Input | Analog Input               |
| AN2      | ON                | AD1PCFG<2>            | Α           | _              | Input | Analog Input               |
| AN3      | ON                | AD1PCFG<3>            | Α           | _              | Input | Analog Input               |
| AN4      | ON                | AD1PCFG<4>            | Α           | _              | Input | Analog Input               |
| AN5      | ON                | AD1PCFG<5>            | Α           | _              | Input | Analog Input               |
| AN6      | ON                | AD1PCFG<6>            | Α           | _              | Input | Analog Input               |
| AN7      | ON                | AD1PCFG<7>            | Α           | _              | Input | Analog Input               |
| AN8      | ON                | AD1PCFG<8>            | Α           | _              | Input | Analog Input               |
| AN9      | ON                | AD1PCFG<9>            | Α           | _              | Input | Analog Input               |
| AN10     | ON                | AD1PCFG<10>           | Α           | _              | Input | Analog Input               |
| AN11     | ON                | AD1PCFG<11>           | Α           | _              | Input | Analog Input               |
| AN12     | ON                | AD1PCFG<12>           | Α           | _              | Input | Analog Input               |
| AN13     | ON                | AD1PCFG<13>           | Α           | _              | Input | Analog Input               |
| AN14     | ON                | AD1PCFG<14>           | Α           | _              | Input | Analog Input               |
| AN15     | ON                | AD1PCFG<15>           | Α           | _              | Input | Analog Input               |
| VREF+    | ON                | AD1CON2<15:13>        | Р           | _              | _     | Positive Voltage Reference |
| VREF-    | ON                | AD1CON2<15:13>        | Р           | _              | _     | Negative Voltage Reference |

Legend: ST = Schmitt Trigger input with CMOS levels
I = Input
O = Output

A = Analog P = Power

## **Timers**

טיימר הוא רכיב בעל גביש שנותן פולס בסוף כל פרק זמן (קבוע).

#### <u>אורך פרק הזמן</u>

אורך האינטרוול קבוע ומוגדר מראש ע"י הערכי PR,TMR,PS של הטיימר באופן הבא:

$$t = \frac{PS * (PR - TMR)}{f} [sec]$$

in PIC32: 
$$f = 80MHz = 80 * 10^6 Hz (Hz = \frac{1}{\text{Sec}})$$

עושים init לטיימר באופן הבא (בדוגמא מאתחלים ומפעילים את TIMER1):

<u>שלב 1</u> – מקור הפולסים:



#### שלב 2 - ערכים שקובעים את האינטרוול בין הפולסים של הגביש:



00:1, 01:8, 10:64, 11: 256 :timer1 – ביטים שמייצגים מספר 2 = PS0+PS1

(בצד שמאל ערך הביטים בצד ימין הערך האמיתי של הPrescaler).

ככל שהPS גדול יותר, כך האינטרוול יהיה ארוך/איטי יותר.

שלב 3 – שורת איתחול נוספת (לא הורחב עליה)

T1CONbits.TGATE=0;

(חשוב!) IF שלב 4 – איפוס ביט

רגיסטר הInterrupt Flag) IF) של הטיימר הוא ביט שעולה (מקבל ערך 1) בכל פעם שהגביש נותן פולס.

... אם ברגיסטר היה ערך 1 וניתן פולס אז הוא ישאר

לכן לפני שהIF עולה ל-1 צריך לאפס אותו.

```
IFS0bits.T1IF=0;
```

<u>שלב 5</u> – הפעלת הטיימר

```
T1CONbits.ON=1;
```

#### :דוגמא

תוכנית שגורמת ללד הראשון לשנות מצב (להתכבות\להידלק) כל 0.2 שניות.

```
/*Left digit represents the X number
 Right digit represents te Y number*/
void main() {
    /*INIT TMR1*/
    //stage1
   TMR1=0;
   PR1=0xFFFF; //0xFFFF = 65535
   T1CONbits.TCKPS0=1;
   T1CONbits.TCKPS1=1;
   //stage2
   T1CONbits.TCS=0;
   //stage 3
   T1CONbits.TGATE=0;
   TRISA = 0;
   PORTA = 0;
   while(1){
       PORTAbits.RA0^=1;
        //DELAY by TMR1
                                    //IF down (stag4)
        IFSObits.T1IF=0;
       T1CONbits.ON=1;
                                    //TMR1 on (stage5)
                                   //wait until IF up
       while(!IFSObits.T1IF);
       T1CONbits.ON=0;
                                    //TMR1 off
   }
```

## <u>טיימרים: (בINIT ניתנו הזמנים המקסימליים לאינטרוול)</u>

#### TMR1





```
/*INIT TMR1*/
                                void delay(void) {
//stage1 (time=0.209 sec)
                                    T1CONbits.ON=0; //TMR off
TMR_{1=0};
PR1=0xFFFF; //=65535
                                    //stage1
T1CONbits.TCKPS0=1; //PS=256
                                    TMR1=0;
                                    PR1=0xFFFF; //0xFFFF = 65535
T1CONbits.TCKPS1=1;
//stage2
                                    T1CONbits.TCKPS0=1;
T1CONbits.TCS=0;
                                    T1CONbits.TCKPS1=1;
//stage 3
                                    //stage2
T1CONbits.TGATE=0;
                                    T1CONbits.TCS=0;
T1CONbits.TSYNC=1;
                                    //stage 3
//stag4
                                    T1CONbits.TGATE=0;
IFSObits.T1IF=0;
                                    T1CONbits.TSYNC=1;
//staq5
                                    //stag4
T1CONbits.ON=1;
                                    IFSObits.T1IF=0;
                                    //stag5
                                    T1CONbits.ON=1;
                                    while(!IFSObits.T1IF);//waiting until IF up
                                }
```

#### TMR2,3,4,5

#### FIGURE 14-1: TIMER2, 3, 4, 5 BLOCK DIAGRAM (16-BIT)



```
/*INIT TMR2*/
                                void delay(void){
//stage1 (time=0.209 sec)
                                    T2CONbits.ON=0; //TMR off
TMR_{2=0};
PR2=0xFFFF; //=65535
                                    //stage1
T2CONbits.TCKPS0=1; //PS=256
                                    TMR2=0;
T2CONbits.TCKPS1=1;
                                    PR2=0xFFFF; //0xFFFF = 65535
T2CONbits.TCKPS2=1;
                                    T2CONbits.TCKPS0=1;
//stage2
                                    T2CONbits.TCKPS1=1;
T2CONbits.TCS=0;
                                    T2CONbits.TCKPS2=1;
//stage 3
                                    //stage2
T2CONbits.TGATE=0;
                                    T2CONbits.TCS=0;
//stag4
                                    //stage 3
IFSObits.T2IF=0;
                                    T2CONbits.TGATE=0;
                                    //stag4
//stag5
T2CONbits.ON=1;
                                    IFSObits.T2IF=0;
                                    //stag5
                                    T2CONbits.ON=1;
                                    while(!IFSObits.T2IF);//waiting until IF up
```

#### **TMR23,45**

מורכב מ2 הטיימרים TMR2, TMR3 על מנת לתת טיימר אחד שהאינטרוול שלו יותר גדול (הספירה מTMR היא 32 ביט ולא 16 ביט).

#### :TMR&PR •

- ַכל <u>שאר הרגיסטרים הם של TMR2</u> למעט <u>הIF ששייך לTMR3</u>
- T2CONbits.T32=1; כ"י הפעולה: <u>32bit mode</u> •



```
/*INIT TMR23*/
                                   void delay(void) {
                                       T2CONbits.ON=0;
                                       T3CONbits.ON=0;
//stage1(time=1sec)
                                       //stage1(time=1sec)
TMR_{3}=0;
           //TMR msb
                                       TMR3=0;
                                                  //TMR msb
TMR_{2=0};
            //TMR lsb
                                       TMR2=0;
                                                   //TMR lsb
PR_3 = 0x4;
            //PR 0x4c4b4=312500
                                       PR3=0x4;
                                                   //PR msb
PR_2 = 0xc4b4;
                                       PR2=0xc4b4; //PR lsb
T2CONbits.TCKPS0=1;// PS=256
                                       T2CONbits.TCKPS0=1;// PS=256
T2CONbits.TCKPS1=1;
                                       T2CONbits.TCKPS1=1;
T2CONbits.TCKPS2=1;
                                       T2CONbits.TCKPS2=1;
//stage2
                                       //stage2
T2CONbits.TCS=0;
                                       T2CONbits.TCS=0;
//stage 3
                                       //stage3
T2CONbits.TGATE=0;
                                       T2CONbits.TGATE=0;
//staq4
                                       //stage4
IFSObits.T2IF=0;
                                       IFSObits.T2IF=0;
IFSObits.T3IF=0;
                                       IFSObits.T3IF=0;
                                       //stage5
T2CONbits.T32=1;//mode 32bit
                                       T2CONbits.T32=1;//mode 32bit
T2CONbits.ON=1;
                                       T2CONbits.ON=1;
                                       while(!IFSObits.T3IF);
```

## **Interrupts**

ניתן להגדיר לכל טיימר פונקציית interrupt שכל פעם שהIF של הטיימר עולה ל1 (הגביש נתן פולס) אז הפונקציה מתבצעת אוטומטית.

(ניתן להגדיר פונקציית פסיקה לכל מערכת שנותנת interrupt) פיזי ל23).

- כשמגדירים את הפונקציה מגדירים priority וגם subpriority כך שאם 2 פונקציות
   אמורות להיתבצע באותו הזמן אז תתבצע זו עם העדיפות הגבוהה יותר.
  - בנוסף חייבים לייבא את: sys/attribs.h
  - 7 **Priority** פסיקה בעדיפות הגבוהה ביותר, 1 בעדיפות הנמוכה ביותר, 0 פסיקה לא פעילה.
    - . עדיפות גבוהה, 1 עדיפות נמוכה 3 **Subpriority(1-3)** •

#### TMR2,3,4,5

```
#include <xc.h>
/*standard "pragma config's" in here... */
#include <sys/attribs.h>
void __ISR(_TIMER_5_VECTOR, ipl2auto) Timer5SR(void);
void
       ISR( TIMER <mark>5</mark> VECTOR, ipl<mark>2</mark>)    Timer<mark>5</mark>SR(void) {
  PORTA++;
   IFS0bits.T\frac{5}{1}IF = 0;
}
void main() {
  int j;
   TRISA &= 0xff00;
    /*INIT TMR5*/
    //stage1 (time=0.209 sec)
    TMR_{5}=0;
   PR<mark>5=0xFFFF; //=65535</mark>
   T5CONbits.TCKPS0=1; //PS=256
   T5CONbits.TCKPS1=1;
   T5CONbits.TCKPS2=1;
    //stage2
   T5CONbits.TCS=0;
    //stage 3
   T5CONbits.TGATE=0;
    //staq4
   IFSObits.T5IF=0;
    //staq5
    T5CONbits.ON=1;
   /*Priority TMR<mark>5</mark>*/
   IPC5bits.T5IP = 2; // Priority
   IPC_{5}^{5}bits.T_{5}^{5}IS = 0; // Subpriority
   IECObits.T5IE = 1; // Enable Interrupt
   /*Enable Interrupts*/
   INTCONbits.MVEC = 1; //vector interrupt
   asm("ei");
                         //on interrupt
}
```

### Timer1

```
#include <xc.h>
/*standard "pragma config's" in here... */
#include <sys/attribs.h>
void __ISR(_TIMER_1_VECTOR, ipl5auto) Timer1SR(void);
void __ISR(_TIMER_1_VECTOR, ipl5) Timer1SR(void) {
   PORTA++;
   IFSObits.T1IF = 0;
}
void main() {
  int j;
   TRISA &= 0xff00;
    /*INIT TMR1*/
    //stage1 (time=0.209 sec)
    TMR_{1=0};
    PR<mark>1=0xFFFF; //=65535</mark>
    T1CONbits.TCKPS0=1; //PS=256
    T1CONbits.TCKPS1=1;
    //stage2
    T1CONbits.TCS=0;
    //stage 3
    T1CONbits.TGATE=0;
    //stag4
    IFSObits.T1IF=0;
    //stag5
    T1CONbits.ON=1;
   /*Priority TMR1*/
   IPC1bits.T1IP = 5; // Priority
   IPC_{1}^{1}bits.T_{1}^{1}IS = 0; // Subpriority
   IECObits.T1IE = 1; // Enable Interrupt
   /*Enable Interrupts*/
   INTCONbits.MVEC = 1; //vector interrupt
                       //INTERRUPT PROXIMITY TIMER REGISTER
   IPTMR = 0;
   asm("ei");
                          //on interrupt
```

### **Timer23,45**

```
#include <xc.h>
/*standard "pragma config's" in here... */
#include <sys/attribs.h>
void __ISR(_TIMER_3_VECTOR, ipl6auto) Timer23SR(void);
void __ISR(_TIMER_3_VECTOR, ipl6) Timer23SR(void) {
     PORTA++;
      IFSObits.T3IF = 0;
}
void main() {
    int j;
     TRISA &= 0xff00;
     PORTA = 0;
      /*INIT TMR23*/
      //stage1(time=1sec)
      TMR_3 = 0; //TMR msb
      TMR_2^2 = 0; //TMR lsb
      PR_3 = 0x4; //PR 0x4c4b4 = 312500
      PR2 = 0xc4b4;
      T_{2}^{2}CONbits.TCKPS0 = 1; // PS=256
      T_2^{2}CONbits.TCKPS1 = 1;
     T_2^{2}CONbits.T_{2}^{2}CONbits.T_{2}^{2}CONbits.T_{2}^{2}CONbits.T_{2}^{2}CONbits.T_{2}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CONbits.T_{3}^{2}CON
      //stage2
     T_2^{2}CONbits.T_{CS} = 0;
      //stage 3
      T_2^{2}CONbits.T_3^{2}GATE = 0;
      //stag4
      IFSObits.T_2^2IF = 0;
      IFS0bits.T\frac{3}{2}IF = 0;
      //stag5
      T_2^{2}CONbits.T_3^{2} = 1; //mode 32bit
     T_2^{2}CONbits.ON = 1;
      /*Priority TMR23*/
      IPC_3^3bits.T_3^3IP = 6; // priority
      IPC_{3}^{3}bits.T_{3}^{3}IS = 0; // subpriority
      IECObits.T3IE = 1; // Enable Interrupt
      /*Enable Interrupts*/
      INTCONbits.MVEC = 1; //vector interrupt
      IPTMR = 0; //INTERRUPT PROXIMITY TIMER REGISTER
      asm("ei"); //on interrupt
```